<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
</head>

<body>
  <input type="text" id="txt"><button id="btn">上传</button>
  <div id="show">
    <span>本套房子的价格：</span><span id="total"></span>
  </div>
  <script>


    // var room = {
    //   name: "小王",
    //   phone: "18888888888",
    //   room: 180,
    //   price: 150
    // }
    // // 
    // var temp = null;
    // Object.defineProperty(obj, "sex", {
    //   get: function () {
    //     return temp
    //   },
    //   set: function (val) {
    //     console.log(val)
    //     temp = val;
    //   }
    //   // value: "女",
    //   // configurable: true,
    //   // enumerable: false,
    //   // writable: false
    // })
    // obj.sex = "男"
    // console.log(obj)


    // proxy()---Proxy 可以对目标对象的读取、函数调用等操作进行拦截，
    // 然后进行操作处理。它不直接操作对象，而是像代理模式，
    // 通过对象的代理对象进行操作，在进行这些操作时，可以添加一些需要的额外操作。
    var room = { //目标对象
      name: "小王",
      phone: "18888888888",
      room: 180,
      price: 150
    }
    // proxy 代理room对象 new proxy(代理的对象,{get(){},set(){}})
    // var lianjia = new Proxy(room, {
    //   get(target, key) {
    //     if (key == "price") {
    //       return target[key] + 30
    //     } else {
    //       return target[key]
    //     }
    //   },
    //   set() { } //拦截对目标对象的操作
    // })
    // console.log(lianjia.price)

    var btn = document.getElementById("btn");
    btn.onclick = function () {
      var txtVal = document.getElementById("txt").value;
      var lianjia = new Proxy(room, {
        get(target, key) {
          if (key == "price") {
            return target[key] + 30
          } else {
            return target[key]
          }
        },
        set(target, key, value) {
          if (key == "price") {
            if (value > 300) {
              target[key] = 300;
            } else {
              target[key] = value;
            }
          }
        }
      })
      var total = document.getElementById("total");

      lianjia.price = Number(txtVal); //设置
      total.innerHTML = lianjia.price;//获取
      console.log(room)
    }


  </script>
</body>

</html>